MongoDB Atlas® Admin API
Overview
The MongoDB Atlas DBaaS service (www.mongodb.com/atlas) is a popular cloud datastore. There is an administration API for interacting with Atlas which includes accessing configuration information such as clusters, along with retrieving invoices. This API is independent from using the MongoDB query language to query the stored application data itself.
The beneficial use cases of this interface include:
- Providing consolidate analysis and configuration information on your Atlas deployment saving significant page navigation to each of the many separate information areas,
- Summarizing organization and project level information which can include interactive links to the MongoDB web console, and
- Analyzing your Atlas invoices.
For more details see https://www.mongodb.com/docs/atlas/api/.
Prerequisites and Troubleshooting Considerations
The Qarbine Administrator configures Data Services to use an Atlas API key to access a particular MongoDB Atlas instance. That API key has various options for permission and network access rules as well. When this is not done the following is likely going to be shown.
In addition, if there may be restrictions regarding which IP addresses can use the Atlas token to access the Atlas Admin IP objects. As a result you may run into the following error.
The address in question is that of the Qarbine host trying to access the Atlas instance and not the end user’s browser.
When running a query from a “not allowed” IP address for the associated Atlas API key an error may also be shown in ways such as this
or this
The separate document for Qarbine administrators has more details describing MongoDB Atlas query integrations and permissions.
When running queries as experiences an error such as the following
Then dynamic data services may be in place. Double check the user’s annotations for “orgName”. This may be defined by the user and is visible by clicking in the upper right hand corner
And clicking on the tab shown below.
The Qarbine Administrator should check annotations for the associated user’s Principal and any access group objects. This is done within the Administration tool window.
Data Visibility
Since Qarbine the software is deployed by you the customer, Qarbine the company has zero visibility to your data retrieved by this or any other Qarbine data interface.
Sample Templates
There are many prebuilt Atlas operational templates which reference a Qarbine Data Source that require Atlas API credentials. These reports include billing analysis for example. These reports are different from the analysis reports on your data stored within Atlas. As a reminder, if MongoDB Atlas operational reports are going to be run, then Qarbine compute node IP addresses must be added to the Atlas API allowed IP list, not the IP address of user browsers.
For reports on MongoDB databases and collections see the other example folder shown below.
The Qarbine Administrator can define a data service “Atlas Virtual DB” to satisfy the data service references from these components.
Defining a Data Source
Overview
A Data Source is a Qarbine component responsible for retrieving data from somewhere. At a high level it has a name, a description and some arbitrary query string which when sent to the associated Qarbine Data Service endpoint returns some data. In this writeup we are using the MongoDB Atlas Administration API to retrieve information. The overall execution flow for an analysis, including the optional prompt component, is shown below.
A single data source can be referenced by name from multiple Qarbine template components. This enables a single point of change when perhaps, an index is added, or some other query tweak is necessary. The alternative is to attempt to find all templates impacted by a schema or index change for example. The component reusability is especially beneficial when team members have varying roles and skills.
Querying Language
MongoDB Atlas provides an API to interact with many of the configuration and operational aspects of Atlas. Qarbine provides a MongoDB Query Language (MQL) and SQL interface to this set of data. Your familiar query skills can be applied to retrieve and present Atlas configuration and operational information.
For details on the query options see the document at doc.qarbine.com within the area highlighted below.
Initial Component Setup
Open a new Data Source Designer tool via:
- Home page,
- Signing on and choosing Data Source Designer front he drop down, or
- The hamburger menu option on any tool.
If you already have a Data Source Designer tool open the start a new component by clicking
The Qarbine Administrator defines a Qarbine Data Service to access a MongoDB Atlas instance using the Atlas API. The name of the Data Service will be selectable by you if so desired by the administrator.
This example uses an explicit Data Service set up by the Qarbine administrator.
Next select a “database” from the dropdown.
The collections drop down is populated now as shown below.
These logical collections are described in more detail in the document referenced by the “Query Language” section above.
To get general structure information about a particular collection select it from the dropdown.
Managing Answer Set Size
The default maximum number of rows starts off at 25 for a new data source. This is useful to evolve a query from a concept to one that you have verified returns the desired answer set. As noted, any native way of limiting an answer set size is the preferred approach. This setting is in the component dialog as shown below and also accessible by clicking the ‘Gear’ icon.
Once you are done drafting you can adjust this parameter. A “0” indicates there is no maximum. A number greater than 0 indicates to limit the final answer set size to that number of rows. This answer set truncation comes after any native query limit. So, if the answer set from the data endpoint is quite large, that content has to be returned to the Qarbine host. It then may truncate the number of rows. It is best to truncate at the query level (i.e., use a limit) to reduce the content sent from the data endpoint to the Qarbine host in the first place.
Running the Query
As a query specification enter the following MQL
db.orgClusters.find()
or the equivalent SQL
select * from orgClusters
To run this click
The Atlas API query is run and the results are shown.
Selecting a row populates the details area to the right.
This Atlas instance named “vizy” has 2 clusters as indicated in the embedded clusters array.
In the standard MongoDB Atlas console this is shown for that group\project.
The MongoDB Atlas console provides navigation options for many properties of an Atlas deployment. Qarbine’s Atlas Admin API feature lets you consolidate many of them into a single, quickly reviewable analysis. The analysis can include drilldown and other interactive features as well.
Using Prompts
Overview
Qarbine prompts provide a way to obtain runtime values and variables for data source and template execution. To avoid hardcoding, prompts can use macro formulas to run queries which populate list widgets. Prompts are defined in a no code manner using the Prompt Designer. Shown below is the execution flow when there is a Prompt component.
MongoDB Atlas API Aware Prompts
Most of the Atlas API queries have either an organization or a group project associated with them. The MongoDB Atlas Admin API data model is described in the data interactions document noted in the “Query Language” section above.
There are several prebuilt prompt components for use by MongoDB Atlas Admin API components. Below is one to project for a group\project of an organization.
Let’s create a retrieval specification that uses one of these built in prompts. To reference one of these MongoDB Atlas Admin API aware prompts click
Activate the Prompt tab.
Choose the drop down option shown below.
Click the “Choose from catalog” button.
Navigate to the folder shown.
There are several predefined prompts. For this example choose the one highlighted below.
Click
The prompt reference is filled in.
Close the properties dialog by clicking
For this example we are going to get more details on the organization’s clusters. To get a general idea of that information choose the collection noted below.
For an initial query enter the following.
db.[! @group.id !].clusters.find().sort( {name:1} )
It is equivalent to
select * from [! @group.id !].clusters order by name
At this point when running the component the prompt is presented for the user to select an organization and a contained group. Two runtime variables are set: “org” and “group”. These objects each have a name and an id field. The group object’s id value is inserted into the query using the block notation “[! … !]”. For example, if the group object has a name of “vizy” and id of “abcdefg1213456” then the effective query is
db.abcdefg1213456.clusters.find().sort({name:1} )
or
select * from abcdefg123456.clusters order by name
Click the run button
A prompt with 2 lists appears as shown below.
Selecting an organization in the left hand list populates the right hand list.
Accept the prompt values by clicking
The query is adjusted as described above and run. The results are then shown.
Click on a row to see its details on the right hand side panel.
Adjusting Maximum Rows
Recall the default maximum rows at the component level is 25. At this point you can change that setting by clicking.
Adjust the setting to “0” indicating no Qarbine answer set truncation.
Click
Saving Your Component
Save this new data source component by clicking
Navigate to the target catalog folder within the dialog.
Fill in the properties as desired.
Click
This data source is now stored in the catalog and may be referenced by other components. It is also remembered as a recent data source.
Using the Template Designer
Overview
The next step is to format a detailed report for the data retrieved by the data source just defined. The result can include interactive components and even include links to open up the MongoDB Atlas console pages. Below is a sample output which includes interactive buttons to open corresponding MongoDB Atlas web console pages.
Specifying the Analysis Data
Open the Template Designer.
Open the properties dialog by clicking .
The initial data retrieval is shown below.
. . .
Choose the dropdown as shown and click the highlighted icon.
In the dialog listing, choose the Data Source you just created above.
Click OK to close the selection dialog.
The component reference is filled in.
Click OK to close the template properties dialog.
Defining the Initial Template Cells
The right hand side of the Template Designer shows the general properties of the data expected to be returned from the data source just selected.
At this point in time it is useful to still have the Data Source Designer open to see actual values of these properties. If you do not have one open then simply open up another tab with the Data Source Designer, load your data source, and run it.
As a start let’s create cells to display the chosen organization and groups. Click the grid position shown below.
Enter the formula as shown below and press enter.
The line now shows
Click just to its right.
Enter the formula below and press enter.
= @org.name
Recall the prompt sets an organization object value into the “org” variable and a group object into “group”. This formula obtains the “name” field’s value from the “org” object variable. The line now looks like the following.
The cell is a bit narrow so adjust it via the width entry field or ‘>’ button.
The line now looks like the following.
Add another report header line by clicking
Perform the same steps for the group variable on the additional report header line. The lines should end up looking like the following.
For each of these lines, select them in the left hand side
and then click
The lines now look like the following
Next we start defining the cells for the body section, Click the grid cell shown below.
On the right side scroll down and select the field shown.
Click
A new cell is added to the template grid and it is selected.
The widget will vary based on sample data. Increase the width as shown below.
By default a new cell is set to occupy at most 40 grid positions. The formula may use ‘#FIELD_NAME’ or the equivalent “@current.FIELD_NAME”.
Click to its right to select another empty grid location.
On the right side scroll down and select the field shown.
Click
A new cell is added to the template grid and it is selected.
Select the body line itself by clicking on the far left line label.
Bold all of the cells by clicking
The updated cells are shown below
Add another body line for additional content by clicking
The end result is going to be
The cell positions and formulas are shown below.
The disk size cell at position 43 uses the concat() macro function to concatenate the diskSizeGB value with the string “GB”.
Add another body line to separate out each cluster in the displayed result by clicking
The body section is shown below.
Running the Initial Template
Run the template by clicking
The referenced Data Source references a Prompt so that component is run and presents to the user the following dialog.
As before choose an organization and a group and then click
At this point the output is shown below.
For each cluster in the chosen group the body section is iterated through. In this example there are 2 clusters so we see the output from running through the body section twice.
Saving Your Work
To save your template click
Navigate to the target catalog folder
Fill in the properties as desired.
Click
Adding Other Cluster Fields
From here we can add another body line by selecting the body line in the left hand area and then clicking one of the plus button options (add a line above or below).
Click the grid location shown below.
In the formula entry field enter “Autoscaling” and click enter to add a label.
Click the grid position to its right.
On the right hand side scroll down and select the field highlighted below.
Click
A new cell is added with the formula
and the template’s grid now shows.
Since the property was a boolean, Qarbine’s boolean graphic custom cell was used. This is one of many custom cells Qarbine provides for presentation and interactive flexibility beyond static text found in other tools.
Additional cells can be added to the 2nd body line and an additional blank line added for formatting. The updated template is shown below.
Running this results in the following.
Save the updated template by clicking
It is also remembered as a recent template.
Qarbine and MongoDB Web Console Interaction
The result of the following steps is an analysis that includes interactive buttons and connection string details. Shown below is the output for one of the clusters.
The vertical red line indicates the details on the standard and SRV connection strings for each cluster. The cells for this body line are shown below.
For the organization an interactive button is used via the button custom cell. Its formula is
= urlAction(concat("https://cloud.mongodb.com/v2#/org/", @org.id, "/projects"))
On the right hand side panel, its “Icon URL” formula is
baseFileUrl("asset/logo/mongoDb.png")
For the group an interactive “Open URL” custom cell is used to show an alternative to the button technique. Its formula is
concat("https://cloud.mongodb.com/v2/", @group.id, "#/overview")
The button custom cell provides a lot more presentation flexibility. Interacting with either of these custom cells in the result opens the appropriate MongoDB console page. This enables MongoDB developers to rapidly move from a Qarbine analysis to the MongoDB web console.
Save the updated template by clicking
Run the template and review the results.
Clicking the left side icon here
opens the standard MongoDB Atlas organization page (if necessary you will be asked to log in!)
Clicking the left side icon here
opens the standard MongoDB Atlas project page (if necessary you will be asked to log in!)
These are just a few examples of how Qarbine can provide detailed MongoDB Atlas operational information from which you can easily open specific MongoDB Atlas web console pages.